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ا س 


الجن الأول 


ھن قبل المشروے العام 
OmarSoft‏ 


SoftOmar@hotmail.com 
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بسه الله الرحمن الرحيه 


ف 
)السلاء عليكه ورحمة الله وبركاټه 
E E DE‏ 


أصبح قواعد المعطيات الي تعټمد علي السرفيس في وتنا هذا الأكثر شيوعا والأفضل تعاملا التي عنما : ا50۵ 
server , MySQL,....‏ 
والملاحظ انعا تتعامل بلغة ا50 التي أحد ثبت ثورة هائلة في مجال التعاعل مع المعطيايت » بساطة في البناء وقوة قي 
القعاعل 


لهذا ارقأيت البدء إن شاء الله فيي حورة تعليمية هن التنصيدج إلي الإحترافے فيي اy5S0(‏ . 


قد بفول البعض لماذا (S0۵1‏ : 


- کل مبرمج و کل صاحب مشروع یرید ان یکون مشروعه ناجح و یرید ان ینفذ کل نقاط 
ببساطة هنا : بساطة الإستعلامات الاه5) بالتالي يجب استعمال ا۷5" اولا لأنها تلبي هذه 
البساطة و ثانيا لأنها اسرع. 

- ا M50‏ لها الأفضلية في التعامل مع صفحات الويب ( ۶۳4۲) ... 

- سهلة التنبيت و متوفرة مجانا 

- إذا تمكنت من تعلم الإستعلامات (501) فلن تجد صعوبة في تعلم ٣٥۷٥ء‏ ا5۵ وغيرها... 


وبال الټوفيق 
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الدرس الأول 


تحمیل N۷5۵1‏ 
تثبیت ۸۷5۵1 بالتفصيل 


1- تحمیل ¥SQ1‏ ×5 : 
بما ان البرنامج مجاني فيمكن تحميله من موقعه مباشرة على الرابط التالي : 
http://dev.mysgl.com/get/Downloads/MySQL-5.0/mysgl-5.0.67-‏ 


/win32.zip/from/http://mir2.ovh.net/ftp.mysal.com 


ويمكنك زيارة موقعه لتحميل اخر نسخة من هنا 


/http://www.mysql.com 
: شرم التقصيب‎ -2 
>> اتبع الخطوات التالية‎ 


rss sy SAL 


a mysql-gui-tools-5,O-F1A-wmin 32 
I pî Package Windows Installer 


تت 1 فیس 
pk‏ سار س 


Ê MYSQL 


Welcome to the Setup Wizard for MySQL 
SeEryer. 5.0 


The Setup Wizard will install MySAL Server 5,0 release 5,0,45 
on Your computer, To continue, click ext, 


WARNINMS: This program is protected by copYrighE law, 
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1 MySQL Server 31.0 - Setup Wizard 


Sep Type 


Lhoaose the setup type that best sits Your needs, 


Please select a setup type, 


(® Typical 
Lamman program features will be installed. Recommended Far 
general use, 


0 ا‎ 
| ا‎ program Features will be tall. (ReUires the mast disk 


مدای مپندسي البرمجة 
ا i Luslomı DZIN F‏ 


thooseé which program FeEaUrES Y1 mı rista arid | where they‏ اس 
٣ ill be installed, E o E USES;‏ 


MySQL Enter prise 


comprehensive off 
software, services arf _ 
business achieves the highest levels of reliabil 


security and uptime. 


Enterprise | AnEnterprise Subscription includes: 3 


1. The MySQL Enterprise Server - The most rellable, secure, and fd u 
version of the worlds most popular open source database. . 


2. The MySQL Monitoring and Adv 5 
database assistant. 


3. MySQL Productlon Support - Techr E 
YOU need It, along. with: service packs 5, hı ot-fixe res: andl mc 


EO MIO 0I 00 Ck More “Î or VISE WWI SL. COM EN ter prÎSE 


i MySQL Server 5.0 - Setup Wizard 
Wizard Completed 


setup has Finished installing MySQL Seryer 5,0, lick Fin 
exit the wizard, 


Lonfigure the MIySHL Seryer now 


Lise this option to generate ari opLimized MySQL config 
file, sep ã Windows service running ûn a dedicated pork 
and to set thE password För Ehëe rao account, 


البرمجة 
DZINFO‏ 


منتدى مهندسي ائبرمجة http://www.dzinfo.net‏ صفحة 4 


MySQL Server Instance Configuration Wizard 


YYelcome to the MySQL Server Instance 
Configuration YYizard 1.0.8 5 


The Lonfiguration wizard will alae you Eo configure the 
MYSOL SErwEr 5.U server instance, To Lontinuê, click 
ext, 


منتد ی تس ى البرمجة 
DZINFO‏ 


MySQL Server Instance Configuration Wizar fl 


MySOL Seryer Instance Lonfiguration 


_onfigure the MySQL Serwer 5,U serwer instance, 


Please selert a configuration type. 


(_) Detailed Configuration 
| Zhodse this configuration pe to create the optimal serwêr setup For 


this marchië, 
الترمجة‎ 


DZINFO 


(ei Standard Configuration 


LISE this only or machines that do fot alrêãdy Fave a MyYSOL sêryer 
installation, This will use a general pürpûse configuration Fûr the 
sêrwer that can bê Einêd annually, 


MySQL Server Instance Configuration Wizard 


PMySOL SerY¥er Instance Configuration 


waonfigure the MySAL Serwer 5,O server insta 


Please set the Windows options; 


[#] Install As Windows SEFYICE 


This is the recommended way to run the MySQL serwer 
û Win das, 


Service Mame! mySaL په‎ 
Launch the MySQL Server automatically 


[¥] Include Bin Directory in Windows PATH 
Check this option to include the directory containing the 
serwer f client executablas in hê Windows PATH Yariãblë 
su they can be called from the command line. 


[_ <eak Jl> J| cene j 
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MySQL Server Instance Configuration Wizard 
mMyYSOL SerYer Instance Configuration 
wonfigure the MwSGL Serwer 5,UÛ server instance, 
Please set the securiEy options. 


Modify Security Settings 


Mem rank password: e Enter the raat password, 


Retwpe: EhëE pãssmûrd, 


toanfirri: 


[Enable raat access fram remote machines 


account arı this server, Please 


[ ltreate ûn Anonyrmûuls ûAclount 
This option will create an anonymous 


nate that Ehis can lead Eo an inšêcutê system, 


MySQL Server Instance Configuration Wizar d 


MySL Seryer Instance Configuration 


w_onfigure the MYSL Server 5,U serwer instance, 


Processing configurakion ... 


ww) Prepare configuration 


write configuration File (CfProgram Filey SRLMySTAL Server S5 Ommy rini)‏ ا 


مبرورت 


لايد ,ان د 


Start serYice 
شکدا‎ 
i Apply security settings 


Lonfiguration file created. 
Windows seryice Iy¥SIL installed. 
SeErYice started successfully. 
Security settings applied. 


Press [Finish ] to close Ehe Yizard. 


al Borland Delphi 7 ۴ 


ar dêfauk F | fi MYSQL Server 5i0 


i Tmitance oi 


DZINFO 
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Enter paszsuorPrÛ]l: ## 


1 2 el ۳ E 


DZINFO 


Enter password]: #wz 

lle lcome to the HySQ4L monitor. Connands end with ; oF “g9. 

Your HyS{4L connection id is 3 

SEPFVYEF YeEFPFSIion: b5 BH. 45-connun it y~nt MHyS4L Lomnmun ity Edition <GPL? 


Type 'help;:" oF '«»h" for help. Type "ce" to clear the buffer. 


mysql? _“ 


DZINFO 


لما تدخل كلمة السر وتخرج عبارة " welcome to the MySQL monitor‏ " كما في الصورة 
الأخير فهنيء لك التثبيت السليم وبهذا يمكنك الآن البدء في التعامل مع قواعد المعطيات والجداول 
التي بداخلها » وسنشاهد ذلك إن شاء الله بالتفصيل في الدرس القادم .... 
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الدرس الثافيي 


ټنټسه تټعلمات آ٩‏ ءل الي قسمین: 
1- lغخة data définition language)D DL ےۓlilqڊll sy‏ 
وهي التي تقوم بإنشاء و تعديل و حذف قواعد المعطیات alter , create, show Jin‏ 


2- lغة‏ llzaلqة‏ lilyqllۓے (data manipulation language)D ML‏ 
وهي التي تتعامل مع المعطيات مباشرة متل ۲٤‏ عء١|‏ , اع 
وسنقوم في هذا الدرس بتعلم التعامل بلغة 001 
تغير كلمة عرور المستخدم : 
سيكون اول شيء نتعلمه هو كيفية تغير كلمة المرور الخاصة بالمستخدم ۲00 . 
هناك طريقتان لتغير كلمة المرور منها : 
1- افتح الكنصول الخاص بالبرنامج كما في الصورة 11 (MySQL Command Line Client)‏ 
وادخل كلمة المرور كما في الصورة 12 من بعد ذلك اكتب الكود التالي : 
set password for root@localhost=password( your password’);‏ 
بحيث 0۲١‏ سءءهم ۲اه في الكود إستبدلها بكلمة المرور الجديدة واضغط على ٥۸)۲ع‏ . 
2- أفتح Server Instance Config Wizard‏ اMySQ‏ من قائمة بدا كما في الصورة 11 
م اشر lEذJ Reconfigure Instance‏ îۃ‏ |ختر Standard Configuration‏ 
ثم ٥×‏ » أعطي في الخانة الأولى كلمة المرور السابقة وفي باقي الخانات الجديدة وهكذا 
قد تمكنا من تغير كلمة المرور للمستخدم أ0ه۲. 


في هذه الفقرة نتعلم كيفية معرفة اسماء قواعد المعطيات و ما تحتويه من جداول وكيفية الدخول 
والخروج منها . 


منتدى مهندسي llبرمجة http://www.dzinfo.net‏ صفحة 8 


ومنه نستنتج أن السرفيس يحتوي مجموعة من قواعد المعطيات وبدورها قواعد المعطيات تحتوي 
على مجموعة من الجداول › وإذا أردنا التفصيل أكثر فحتى الجداول تحتوي مجموعة من الحقول 
وسنخوض فيها بالتفصيل في الدرس القادم . 

1- استعراض قواعد المعطيات ٠‏ 

نفتح الكنصول ونضع الكود التالي 


show databases ; 


nı. MySQL Command Line Client 


Enter passuwoFPûÛ]: #zeجe‎ 

le lcome to the MHySQ4L monitor. LGonmmands end with $; oF ™g.-. 

Your MHyS4L connection 1d is 1 

SHEFNEF YeEFPFSsIioOn: b5 HMH. 4E—comnmun it y~nt HySdAL Commun ity Edition <OGPL? 


Type 'helps;:' or '«xh" for help. Type °c" to clear the buffer. 


Foals in set <H.H3 sec? 


mysql? DZINFO 


يقوم الكود السابق بإظهار اسماء قواعد المعطيات الموجودة وهي informatiion_schema‏ 
myqsl ,test‏ 
2- دخول قاعدة المعطيات ` 
لكي نتمكن من دخول قاعدة المعطيات نستعمل الكود التالي 

use databasename; 
۸2ءءهطهاهل ب إسم قاعدة معطيات التي نريد الدخول إليها » بعدها تخرج عبارة‎ "٠ بحيث نستبدل‎ 
تؤکد دخولك.‎ Database changed 
` مثلا‎ 


nysql#* use information_schenma ; 
Database changed 


nysql+# 14 


3- استعراض الجداول من قاعدة المعطيات ٠:‏ 
بعد إختيارنا لقاعدة المعطيات يمكننا الأن إستعراض الجداول التي بداخلها بنفس الكود الخاص 
بإستعراض قواعد المعطیات مع إستبدJI databases‏ ڊ tables‏ : 


show tables; 
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mysql#* use inforFmatiaon_schema ; 
Database changed 


فتكون النتيجة : 


4- مشاهدة حقول الجدول : 


بعدما تمكنا من معرفة الجداول الموجودة في قاعدة المعطيات 


CHARACTER_ SETS 


COLLAT I ONS 


COLLAT ION_CHARACTER_SET_ APPLICABILITY 


COLUMNS 


COLUMN_PRIUILEGES 
REEY_COLUMN_USAGE 


PROFI LING 
ROUT IMES 
3 GCHEMATA 


3 CHEMA_PRIUILEGES 


STATISTICS 
TABLES 


TABLE_CONS TRA INT S 
TABLE_PRIYILEGES 
TRIGGERS 


US ER_PRIUI LEGES 


نستعمل الكود التالي لمشاهدة حقول الجدول و نوعها: 


بحیث نستبدل ۳٣٥‏ ھہءاطھع ب إسم الجدول مثلا وہہ ںاہCZ‏ 


+ س س س س سے س سے 
Extra‏ 


+ سس ا سس س ت ت ت ست ت ت ست ست ست ست ست ست ست ست ست ست سس ل 
+ سس ا سس س ت ت ست ت ست ت ست ت ست ست ست ست ست ست ست ست سس لإ 


DZINFO 


varchar bi2 2 


uarchartb4? 
arc harFrtb4? 
uarchartb4? 
bigqint<taZl1l ? 
langtext 

uarc hart 3 2? 
uarc hartb4? 
bhigint<aZl ? 
bhigqint<2aZl1 2 
bhigqint<tZl1 ? 
bhigqint<2Z1 ? 
uarc hart b4? 
arc harFrtb4? 
laongtext 

yuarFc hart 3? 
varchar aH? 
varchar BH? 


arc haFt 2b 2 


WI EWS 


(information_schema) ةرlتخnلنl‎ 


describe tablename; 


nysql? descFibe co lunns 


TABLE_CATA LOG 
TABLE_SCHEMA 
TABLE_NAME 
GCOLUMN_NAME 
ORDINAL_POSIT ION 
COLUMN_DEFAULT 

1S5 _NULLA BLE 

DATA_TYPE 

GHA RACT ER_MAR I HUM_LENGTH 
GHA RACT ER_OCT ET _LENGTH 
HUMERIC_PRECIS ION 
HUMERICG_SCA LE 

CHA RACT ER_SET _NAME 
GOLLAT I ON_NAME 
GCOLUMN_TYPE 


PRIVILEGES 
GOLUMN_ COMMENT 


س س س س ل س ل ل ل ل ل ل ل ل ل ن ل ل ل ل ل ن f‏ 


1F Fouws in set ¢H.H3 sec? 


من خلال الصورة يتبين في العمود الأول إسم الحقل و في الثانية نوع الحقل وأما البقية سنتعرف عليها 


بالتفصيل في الدروس المقبلة . 
إضافة: 


- في بعض الأحيان تخطيء في كتابة الكود فتعيد كتابته من جديد وهذا ما يسبب في تضيع الوقت 
يمكنك الضغط على زر أعلى أو أسفل لإظهار الأكواد السابقة ويبقى لك سوى تغير الخطاً في الكتابة . 
- لتسهيل الكتابة و ربح الوقت يمكنك نسخ الكود ومن ثم لصقه في الكنصول مباشرة : 
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ıı. MySQL Command Line Client 


Enter paszsuorFP]: #ee 

le lIcame to the MyS{4L monitor. Lonmnmands end with ; oF “f. 

Your MySQL connection id 13 

SEFYEF Version: b5 BH. 4E—conmnun 1t y-nt MySQL Conmun ity Edition <OPL? 


Type "help;:' oF '«xh"' for help. Type '«c" to clear the buffer. 


nysql+# 


<êlectionner 


Loller 
<êlectionner tout 
GDêfilermant 


Rechercher... مھنڈسی البرمجة‎ prte 
DZINFO 


الدرس )لاله 


إنشاء وحنذوے قاعدة معطیایھ: 
بعدما تعرفا على كيفية إستعراض قواعد المعطيات التي لدينا نقوم الأن بإنشاء قاعدة معطيات جديدة 
لتكن '٥عرهاممء'‏ وذلك بالكود التالي : 


create database employee; 
للتأكد من عمل الكود قم بإستعراض قواعد المعطيات التي لدينا‎ 


nysql#* create database employee ; 
dueFry OK, 1 Fou affected ¢{HA.BHH sec? 


nysql# show databases ; 
+ 
1 


infFforFmat 1o0n__3schema 
emp lo yee 


Fous iIin set <HBH.BHA sec? 


nysq lL? ا البرمد‎ Fri 
DZINFO 


وكذلك يمكننا حذف القاعدة التي نريد بالكود التالي : 
drop database employee;‏ 
في حالة لم تكن متأكد من وجود قاعدة المعطيات لكثرتها يمكنك قطع الشك باليقين بإستخدام الكود التالي: 
drop database if exists employee;‏ 
إنشاء الجداول : 
لإنشاء الجدول لابد ان نحدد قاعدة المعطيات التي سيتم إنشاء الجدول فيها بالكود السابق 


use employee; 


ونعتمد الصيغة التالية لإنشاء جدول ٠‏ 


create table tablename ( table definition ) type=table_type ; 
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بحيث في مكان "٠‏ ۸٠اه‏ نضع إسم الجدول الذي نريد إنشاءه 


ومکان 
ومکان 
HEAP‏ 


definition‏ مااهt‏ نضع إسم الحقل ونوعه وما الخصائص التي يتمتع بها 
table_type‏ نضع نوع انفجدوJ‏ وa: ISAM, MyISAM, InnoDB , BDB, MERGE,‏ 


ونستعمل على العموم النوع .!٣٣۵٥08‏ 


متال: 


use employee; 
create table department 


( 


departmentlD int not null auto_increment primary key , 
name varchar(30) 


rn 
department بحيث إسم الجدول فر‎ 
إسم الحقل الاول‎ depمartment|D‎ 
'' يعني لا يقبل قبل قيمة فارغة‎ int n0 uاا‎ 
۰3.2.1 : نوع الحقل تسلسلي بزيادة واحد‎ هuto_increment‎ 
يعني ان الحقل عبارة عن مفتاح للجدول (يميز المعطيات لا يتكرر)‎ ماimصary‎ key 
, نضع بين حقل وحقل آخر فاصلة‎ 
إسم الحقل الثاني‎ Name 
نوع الحقل عبارة عن كل سلسلة من 30 شيفر ( حرف » رقم › رموز...)‎ varch2۲)30( 


عل كرد الكاض متاه الخال 


show tables; 


ثم نستعمل الكود الخاص بمشاهدة الحقول 


describe department; 


nysql#* use employee ; 

Database changed 

mnysql#* create table department 
م‎ 


department I DÛ int not null auto_incFement pFinary key 
name varchart 38? 


—* type =InnoDB; 
duery OK, HM rows affected, 1 warning <A.H3 sec? 


nys ql 


¥ + ¥ ¥ 
1 1 1 1 
1 1 1 1 
¥ + ¥ ¥ 
1 1 1 1 
1 1 1 1 
1 1 1 1 
1 1 1 1 
F + ¥ ¥ 
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: قطبيق للد روس‎ 
: انسخ الكود التالي‎ 
drop database if exists employee; 
create database employee; 
use employee; 
create table department 
( 
departmentID int not null auto_increment primary key, 
name varchar(30) 
) type=InnoDB; 


create table employee 
( 

employeelD int not null auto_increment primary key, 

name varchar(80), 

job varchar(30), 

departmentID int not null references department(departmentID) 
) type=InnoDB; 


create table employeeSkills 

( 
employeelD int not null references employee(employeelD), 
skill varchar(15) not null, 
primary key (employeelD, skill) 

) type=InnoDB; 


create table client 
( 
clientID int not null auto_increment primary key, 
name varchar(40), 
address varchar(100), 
contactPerson varchar(80), 
contactNumber char(12) 
) type=InnoDB; 


create table assignment 
( 
clientID int not null references client(clientID), 
employeelD int not null references employee(employeelD), 
workdate date not null, 
hours float, 
primary key (clientID, employeelD, workdate) 
) type=InnoDB; 
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و ڪڪ 


الرس الرابج 


خلال هذا الدرس نشاهد كيفية إضافة سجلات في الجداول وكيفية التعامل معها وذلك باستخدام 
EAT‏ 
INSERT‏ 
DELETE‏ 
TRUNCATE‏ 
UPDATE‏ 
NER -1‏ | . تمكن التعليمة N5٤۸١‏ | من إضافة سجل جديد في الجدول المطلوب وذلك بالشكل التالي 
insert into name_table values‏ 
CST );‏ 
ومثلا لإضافة العامل صاحب الإسم †؟arsoصom‏ و يعمل Program me۲‏ في قسم رقم 1 
کون الکود کالتالی ٠‏ 


insert into employee values 


, omarsoft' , 'Programmer' ,1) ; 


الخانة الأولى تركت فارغة لأن الحقل الأول عبارة عن رقم تسلسلي يضاف تلقائيا 
إضافات ٠‏ 
- يمكن إضافة العديد من السجلات في الكود الواحد مثلا : 


insert into employee values 

(7513, Nora Edwards','Programmer',128), 

(9842, 'Ben Smith', 'DBA', 42), 

(6651, 'Ajay Patel', 'Programmer', 128), 

(9006, 'Candy Burnett', 'Systems Administrator', 128); 


- لابد من أن تكون عملية الإضافة داخل نطاق قاعدة المعطيات أي: 
use employee;‏ 


: DELETE-2 
في حالة أردت محوا كل السجلات قبل الإضافة » أضف التعليمة التالية:.‎ 


delete from employee; 


أما لمحو سجل معين فيكون ذلك بالتالي : 


delete from employee where name='omarsoft' ; 
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بحيث يمكنك وضع أي كود ا5۵ وإضافة مء اع قبله تقوم التعليمة بحذف السجلات المؤشرة بال 
SQL‏ . 
TRUNCATE —3‏ : 
تقدم هذه التعليمة وظيفة مسح كامل للسجلات في جدول ما مثلا : 
TRUNCATE TABLE employee ;‏ 


UPDATE —4‏ 
تقوم هذه التعليمة يعمل تحديث لحقل في احد السجلات مثلا ٠‏ 
update employee‏ 
set job='DBA'‏ 
where employeelD='6651:;‏ 
أي انه الوظيفة للعامل ذو الرقم التسلسلي '6651' هي التالية '08۸' 
وهكذا نستطيع تغير ما نشاء من القيم في الحقول باستخدام set‏ و where‏ 


ټهرین : 


: اختر الإجابة الصحيحة التي تقوم بأداء الوظيفة المطلوبة‎ 
a. 
insert into employee values 
set employeelD=NULL, name='Laura Thomson', 
job='Programmer', departmentlD=128; 


b. 


insert employee values 
(NULL, 'Laura Thomson', 'Programmer', 128); 


C. 


insert into employee values 
(NULL, Laura Thomson, Programmer, 128); 


d. 


insert employee values 
(NULL, 'Laura O'Leary', 'Programmer', 128); 
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تمي احقوق حفوظ امنتدق ممنسي الرب 
14/08/2009 
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